home *** CD-ROM | disk | FTP | other *** search
- #!/usr/bin/env python
- # -*- coding: utf-8 -*-
- #
- # (c) Copyright 2003-2008 Hewlett-Packard Development Company, L.P.
- #
- # This program is free software; you can redistribute it and/or modify
- # it under the terms of the GNU General Public License as published by
- # the Free Software Foundation; either version 2 of the License, or
- # (at your option) any later version.
- #
- # This program is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- # GNU General Public License for more details.
- #
- # You should have received a copy of the GNU General Public License
- # along with this program; if not, write to the Free Software
- # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- #
- # Author: Don Welch
- #
-
- __version__ = '6.0'
- __title__ = 'Testpage Print Utility'
- __mod__ = 'hp-testpage'
- __doc__ = "Print a tespage to a printer. Prints a summary of device information and shows the printer's margins."
-
- # Std Lib
- import sys
- import os
- import getopt
- import re
- import time
-
- # Local
- from base.g import *
- from base import device, utils, tui, module
- from prnt import cups
-
-
-
- try:
- mod = module.Module(__mod__, __title__, __version__, __doc__, None,
- (INTERACTIVE_MODE, GUI_MODE),
- (UI_TOOLKIT_QT4,))
-
- mod.setUsage(module.USAGE_FLAG_DEVICE_ARGS)
-
- opts, device_uri, printer_name, mode, ui_toolkit, loc = \
- mod.parseStdOpts()
-
- printer_name, device_uri = mod.getPrinterName(printer_name, device_uri)
- wait_for_printout = False
-
- if mode == GUI_MODE:
- if not utils.canEnterGUIMode4():
- log.error("%s -u/--gui requires Qt4 GUI support. Entering interactive mode." % __mod__)
- mode = INTERACTIVE_MODE
-
- if mode == GUI_MODE:
- try:
- from PyQt4.QtGui import QApplication
- from ui4.printtestpagedialog import PrintTestPageDialog
- except ImportError:
- log.error("Unable to load Qt4 support. Is it installed?")
- sys.exit(1)
-
- log.set_module("%s(UI)" % __mod__)
-
- if 1:
- app = QApplication(sys.argv)
-
- dialog = PrintTestPageDialog(None, printer_name)
- dialog.show()
- try:
- log.debug("Starting GUI loop...")
- app.exec_()
- except KeyboardInterrupt:
- sys.exit(0)
-
- sys.exit(0)
-
- if mode == INTERACTIVE_MODE:
- #else: # INTERACTIVE_MODE
- try:
- d = device.Device(device_uri, printer_name)
- except Error, e:
- log.error("Device error (%s)." % e.msg)
- sys.exit(1)
-
- try:
- try:
- d.open()
- except Error:
- log.error("Unable to print to printer. Please check device and try again.")
- sys.exit(1)
-
- # TODO: Fix the wait for printout stuff... can't get device ID
- # while hp: backend has device open in printing mode...
- wait_for_printout = False
-
- if d.isIdleAndNoError():
- d.close()
- log.info( "Printing test page to printer %s..." % printer_name)
- try:
- d.printTestPage(printer_name)
- except Error, e:
- if e.opt == ERROR_NO_CUPS_QUEUE_FOUND_FOR_DEVICE:
- log.error("No CUPS queue found for device. Please install the printer in CUPS and try again.")
- else:
- log.error("An error occured (code=%d)." % e.opt)
- else:
- if wait_for_printout:
- log.info("Test page has been sent to printer. Waiting for printout to complete...")
-
- time.sleep(5)
- i = 0
-
- while True:
- time.sleep(5)
-
- try:
- d.queryDevice(quick=True)
- except Error, e:
- log.error("An error has occured.")
-
- if d.error_state == ERROR_STATE_CLEAR:
- break
-
- elif d.error_state == ERROR_STATE_ERROR:
- cleanup_spinner()
- log.error("An error has occured (code=%d). Please check the printer and try again." % d.status_code)
- break
-
- elif d.error_state == ERROR_STATE_WARNING:
- cleanup_spinner()
- log.warning("There is a problem with the printer (code=%d). Please check the printer." % d.status_code)
-
- else: # ERROR_STATE_BUSY
- update_spinner()
-
- i += 1
-
- if i > 24: # 2min
- break
-
- cleanup_spinner()
-
- else:
- log.info("Test page has been sent to printer.")
-
- else:
- log.error("Device is busy or in an error state. Please check device and try again.")
- sys.exit(1)
-
-
- finally:
- d.close()
-
- log.info("")
- log.notice("If an error occured, or the test page failed to print, refer to the HPLIP website")
- log.notice("at: http://hplip.sourceforge.net for troubleshooting and support.")
- log.info("")
-
- except KeyboardInterrupt:
- log.error("User exit")
-
- log.info("")
- log.info("Done.")
-